﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.Common;
using Microsoft.Practices.EnterpriseLibrary.Data.Sql;
using Microsoft.Practices.EnterpriseLibrary.Common;
using System.Configuration;
using Insifo.BE.Gcg;

namespace Insifo.DL.Gcg
{
    public class DLContenido
    {
        #region  Members


        
        /// <summary>
        /// Método obtiene las Contenidoes
        /// </summary>
        /// <returns>Devuelve un DataSet</returns>
        public DataSet Listar(BEContenido pbe)
        {
            DataSet ds = new DataSet();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Listar");
            dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;
            try
            {
                ds = sqlDB.ExecuteDataSet(dbCmd);
            }
            catch (Exception)
            {
                throw;
            }
            finally
            {
                dbCmd.Dispose();
            }
            return ds;
        }


        /// <summary>
        /// Método obtiene las Contenidoes
        /// </summary>
        /// <returns>Devuelve un DataSet</returns>
        public DataSet ListarPorSeccion(BEContenido pbe)
        {
            DataSet ds = new DataSet();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Listar_X_Seccion");
            sqlDB.AddInParameter(dbCmd, "@ai_IdSeccion", DbType.Int32, pbe.IdSeccion);
            dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;
            try
            {
                ds = sqlDB.ExecuteDataSet(dbCmd);
            }
            catch (Exception e)
            {
                throw e;
            }
            finally
            {
                //if (dbCmd.Connection.State == ConnectionState.Open)
                //dbCmd.Connection.Close();
                dbCmd.Dispose();
            }
            return ds;
        }


        /// <summary>
        /// Método obtiene las Contenidoes
        /// </summary>
        /// <returns>Devuelve un DataSet</returns>
        public DataSet ListarPorSeccionCodigo(BEContenido pbe)
        {
            DataSet ds = new DataSet();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Listar_X_SeccionCod");
            sqlDB.AddInParameter(dbCmd, "@as_CodigoSeccion", DbType.String, pbe.CodigoSeccion);
            dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;
            try
            {
                ds = sqlDB.ExecuteDataSet(dbCmd);
            }
            catch (Exception e)
            {
                throw e;
            }
            finally
            {
                dbCmd.Dispose();
            }
            return ds;
        }

        /// <summary>
        /// Método obtiene Datos del Usuario
        /// </summary>
        /// <returns>Devuelve un DataSet</returns>
        /// 
        public BEContenido Obtener(BEContenido pbe)
        {
            BEContenido be = new BEContenido();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Obtener");
            try
            {
                dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;
                sqlDB.AddInParameter(dbCmd, "@ai_IdContenido", DbType.Int32, pbe.IdContenido);

                using (IDataReader reader = sqlDB.ExecuteReader(dbCmd))
                {
                    while (reader.Read())
                    {
                        be.CodigoContenido = DBValue.Get<String>(reader, "CodigoContenido");
                        be.Titulo = DBValue.Get<String>(reader, "Titulo");
                        be.TextoIntro = DBValue.Get<String>(reader, "TextoIntro");
                        be.TextoCompleto = DBValue.Get<String>(reader, "TextoCompleto");
                        be.MetaClave = DBValue.Get<String>(reader, "MetaClave");
                        be.MetaDescripcion = DBValue.Get<String>(reader, "MetaDescripcion");
                        be.Url = DBValue.Get<String>(reader, "Url");
                        be.Imagen = DBValue.Get<String>(reader, "Imagen");

                        be.IdSeccion = DBValue.Get<Int32>(reader, "IdSeccion");

                        be.Estado = DBValue.Get<String>(reader, "Estado");
                        be.UsuarioModificacion = DBValue.Get<String>(reader, "UsuarioModificacion");
                        be.FechaModificacion = DBValue.Get<DateTime>(reader, "FechaModificacion");
                        be.UsuarioCreacion = DBValue.Get<String>(reader, "UsuarioCreacion");
                        be.FechaCreacion = DBValue.Get<DateTime>(reader, "FechaCreacion");
                        break;
                    }
                }
            }
            catch (Exception e)
            {
                throw e;
            }

            finally
            {
                dbCmd.Dispose();
            }
            return be;
        }


        /// <summary>
        /// Método obtiene una Contenido
        /// </summary>
        /// <returns>Devuelve Objeto</returns>
        public BEContenido ObtenerPorCodigo(BEContenido pbe)
        {
            BEContenido be = new BEContenido();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GCG_Contenido_Obtener_X_Codigo");
            dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;
            try
            {
                sqlDB.AddInParameter(dbCmd, "@as_CodigoContenido", DbType.String, pbe.CodigoContenido);

                using (IDataReader reader = sqlDB.ExecuteReader(dbCmd))
                {
                    while (reader.Read())
                    {
                        be.Titulo = DBValue.Get<String>(reader, "Titulo");
                        be.TextoIntro = DBValue.Get<String>(reader, "TextoIntro");
                        be.TextoCompleto = DBValue.Get<String>(reader, "TextoCompleto");
                        be.MetaClave = DBValue.Get<String>(reader, "MetaClave");
                        be.MetaDescripcion = DBValue.Get<String>(reader, "MetaDescripcion");
                        be.Url = DBValue.Get<String>(reader, "Url");

                        be.IdSeccion = DBValue.Get<Int32>(reader, "IdSeccion");

                        be.Estado = DBValue.Get<String>(reader, "Estado");
                        be.UsuarioModificacion = DBValue.Get<String>(reader, "UsuarioModificacion");
                        be.FechaModificacion = DBValue.Get<DateTime>(reader, "FechaModificacion");
                        be.UsuarioCreacion = DBValue.Get<String>(reader, "UsuarioCreacion");
                        be.FechaCreacion = DBValue.Get<DateTime>(reader, "FechaCreacion");
                        break;
                    }
                }
            }
            catch (Exception)
            {
                throw;
            }
            finally
            {
                dbCmd.Dispose();
            }
            return be;
        }



        /// <summary>
        /// Método Inserta un Nivel Alerta
        /// </summary>
        /// <returns>Devuelve una entidad</returns>
        public BEContenido Insertar(BEContenido pbe)
        {
            BEContenido be = new BEContenido();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Insertar");

            try
            {
                dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;

                sqlDB.AddInParameter(dbCmd, "@as_CodigoContenido", DbType.String, pbe.CodigoContenido);
                sqlDB.AddInParameter(dbCmd, "@as_Descripcion", DbType.String, pbe.Descripcion);

                sqlDB.AddInParameter(dbCmd, "@as_Estado", DbType.String, pbe.Estado);
                sqlDB.AddInParameter(dbCmd, "@as_UsuarioCreacion", DbType.String, pbe.UsuarioCreacion);

                using (IDataReader reader = sqlDB.ExecuteReader(dbCmd))
                {
                    while (reader.Read())
                    {
                        be.IdContenido = DBValue.Get<int>(reader, "IdContenido");
                        be.FechaCreacion = DBValue.Get<DateTime>(reader, "FechaCreacion");
                        //Error
                        be.Error = DBValue.Get<Int32>(reader, "CodigoError");
                        be.Mensaje = DBValue.Get<String>(reader, "MensajeError");
                        break;
                    }
                }
            }
            catch (Exception e)
            {
                throw e;
            }

            finally
            {
                dbCmd.Dispose();
            }
            return be;
        }

        /// <summary>
        /// Método Actualiza un Nivel Alerta
        /// </summary>
        /// <returns>Devuelve una entidad</returns>
        public BEContenido Actualizar(BEContenido pbe)
        {
            BEContenido be = new BEContenido();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Actualizar");

            try
            {
                dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;

                sqlDB.AddInParameter(dbCmd, "@ai_IdContenido", DbType.Int32, pbe.IdContenido);
                sqlDB.AddInParameter(dbCmd, "@as_CodigoContenido", DbType.String, pbe.CodigoContenido);
                sqlDB.AddInParameter(dbCmd, "@as_Titulo", DbType.String, pbe.Titulo);
                sqlDB.AddInParameter(dbCmd, "@as_TextoIntro", DbType.String, pbe.TextoIntro);
                sqlDB.AddInParameter(dbCmd, "@as_TextoCompleto", DbType.String, pbe.TextoCompleto);
                sqlDB.AddInParameter(dbCmd, "@as_MetaClave", DbType.String, pbe.MetaClave);
                sqlDB.AddInParameter(dbCmd, "@as_MetaDescripcion", DbType.String, pbe.MetaDescripcion);
                sqlDB.AddInParameter(dbCmd, "@as_Imagen", DbType.String, pbe.Imagen);
                sqlDB.AddInParameter(dbCmd, "@as_Url", DbType.String, pbe.Url);
                sqlDB.AddInParameter(dbCmd, "@ai_IdSeccion", DbType.Int32, pbe.IdSeccion);

                sqlDB.AddInParameter(dbCmd, "@as_Estado", DbType.String, pbe.Estado);
                sqlDB.AddInParameter(dbCmd, "@as_UsuarioModificacion", DbType.String, pbe.UsuarioModificacion);

                using (IDataReader reader = sqlDB.ExecuteReader(dbCmd))
                {
                    while (reader.Read())
                    {
                        be.IdContenido = DBValue.Get<Int32>(reader, "IdContenido");
                        be.FechaModificacion = DBValue.Get<DateTime>(reader, "FechaModificacion");
                        //Error
                        be.Error = DBValue.Get<Int32>(reader, "CodigoError");
                        be.Mensaje = DBValue.Get<String>(reader, "MensajeError");
                        break;
                    }
                }
            }
            catch (Exception e)
            {
                throw e;
            }

            finally
            {
                dbCmd.Dispose();
            }
            return be;
        }


        /// <summary>
        /// Método Actualiza el Estado Nivel Alerta
        /// </summary>
        /// <returns>Devuelve una entidad</returns>
        public BEContenido Eliminar(BEContenido pbe)
        {
            BEContenido be = new BEContenido();
            SqlDatabase sqlDB = new SqlDatabase(CadenaConexion.Obtener());
            DbCommand dbCmd = sqlDB.GetStoredProcCommand("uSP_INSIFO_GEN_Contenido_Eliminar");

            try
            {
                dbCmd.CommandTimeout = CadenaConexion.CommandTimeout;

                sqlDB.AddInParameter(dbCmd, "@ai_IdContenido", DbType.Int32, pbe.IdContenido);
                sqlDB.AddInParameter(dbCmd, "@as_Estado", DbType.String, pbe.Estado);
                sqlDB.AddInParameter(dbCmd, "@as_UsuarioModificacion", DbType.String, pbe.UsuarioModificacion);
                sqlDB.AddInParameter(dbCmd, "@adt_FechaModificacion", DbType.DateTime, pbe.FechaModificacion);

                using (IDataReader reader = sqlDB.ExecuteReader(dbCmd))
                {
                    while (reader.Read())
                    {
                        be.IdContenido = DBValue.Get<Int32>(reader, "IdContenido");
                        be.FechaModificacion = DBValue.Get<DateTime>(reader, "FechaModificacion");
                        //Error
                        be.Error = DBValue.Get<Int32>(reader, "CodigoError");
                        be.Mensaje = DBValue.Get<String>(reader, "MensajeError");
                        break;
                    }
                }
            }
            catch (Exception e)
            {
                throw e;
            }

            finally
            {
                dbCmd.Dispose();
            }
            return be;
        }

        #endregion  Members
    }
}
